package com.fengye.algorithms.leecode;

/**
 * 73. 矩阵置零
 * 给定一个 m x n 的矩阵，如果一个元素为 0 ，则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。
 * @Author fengye
 * @Date 2023/3/15 10:50
 **/
public class MatrixZoreMain73 {
    public static void main(String[] args) {

    }

    public void setZeroes(int[][] matrix) {
        int n = matrix.length;
        int m = matrix[0].length;
        boolean[] r = new boolean[n];
        boolean[] c = new boolean[m];

        for(int i = 0; i < n; i++) {
            for (int j = 0; j < m;j++) {
                if(matrix[i][j] == 0) {
                    r[i] = c[j] = true;
                }
            }
        }

        for(int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                if(r[i] || c[j]) {
                    matrix[i][j] = 0;
                }
            }
        }
    }
}
